import hljs from 'highlight.js'; import { IconContext } from 'react-icons'; import { GoFile, GoFileDirectory } from 'react-icons/go'; import ReactMarkdown from 'react-markdown'; import gfm from 'remark-gfm'; import Error from 'next/error'; import path from 'path'; const linkClasses = 'text-blue-600 hover:underline'; const listLinkClasses = 'hover:text-blue-600 hover:underline'; function isNotMaster(pathArray) { if (pathArray.length > 2) { if (pathArray[2] !== 'master') { return true; } else return false; } else return false; } function getSubArray(pathArray, depth) { if (depth === 0) { if (isNotMaster(pathArray)) { return pathArray.slice(0, 1).concat('tree', pathArray[2]); } else return pathArray.slice(0, 1); } else return pathArray.slice(0, 1).concat('tree', pathArray.slice(2, depth + 1)); } function getRawURL(pathArray) { const url = `/${pathArray[0]}/raw/${pathArray.slice(2).join('/')}`; return url; } function getLanguage(filename) { switch (path.extname(filename)) { case '.java': return 'java'; case '.html': case '.xml': return 'xml'; case '.md': return 'md'; case '.c': case '.h': return 'c'; case '.tex': return 'tex'; case '.js': return 'js'; case '.fs': return 'fs'; case '.elm': return 'elm'; case '.json': return 'json'; case '.py': return 'py'; case '.css': return 'css'; default: return 'plaintext'; } } function isImage(filename) { switch (path.extname(filename)) { case '.gif': return true; case '.jpeg': case '.jpg': return true; case '.png': return true; case '.tiff': case '.tif': return true; default: return false; } } async function getServerSideProps(context) { const res = await fetch('http://localhost:3000/api' + context.resolvedUrl); const data = await res.json(); if (data.resultType === 'notFound') { return { notFound: true }; } else { return { props: { data } }; } } function Button({ label, url }) { return ( {label} ); } function RepositoryListing(props) { return (
{props.repositories.map((repo) => (
{repo.name}
))}
); } function MainContentContainer(props) { return (
{props.children}
); } function BreadCrumbTrail(props) { const pathArray = props.pathArray; const recursion = (acc) => { if (acc.length === pathArray.length - 1) { return acc; } else { const subArray = getSubArray(pathArray, acc.length); const breadCrumb = { name: pathArray[acc.length], href: '/' + subArray.join('/'), }; const newAcc = acc.concat([breadCrumb]); return recursion(newAcc); } }; if (pathArray.length < 4) { return null; } const breadCrumbs = recursion([]); // remove repoRequest and commit breadCrumbs.splice(1, 2); return (
{breadCrumbs.map((breadCrumb) => ( / {breadCrumb.name} ))} / {pathArray[pathArray.length - 1]}
); } function DirectoryListing(props) { const resultPath = props.resultPath; const makeURL = (repoRequest, item) => { const parentTail = resultPath.length > 2 ? resultPath.slice(2) : ['master']; const parentPath = resultPath.slice(0, 1).concat(repoRequest, parentTail); const url = '/' + parentPath.join('/') + '/' + item; return url; } return ( ); } function CommitListing(props) { const subArray = props.resultContent.slice(1); return ( ); } function ReadmeDisplay({ resultContent, resultPath }) { const imageURITransformer = (uri) => `/${resultPath[0]}/raw/master/${uri}`; return (
); } function LineNos(props) { const count = props.textBlob.split('\n').length; const lineNos = [...Array(count).keys()].map((x) => x + 1).join('\n'); return (
      {lineNos}
    
); } function CodeBlock({ textBlob, resultPath }) { const language = getLanguage(resultPath[resultPath.length - 1]); const highlightedHTML = hljs.highlight(textBlob, { language: language, ignoreIllegals: true }).value; return (
      
    
); } function TextDisplayGrid({ textBlob, resultPath }) { return (
); } function TextBlobArea({ resultContent, resultPath }) { return (
); } function BinaryBlobArea({ resultPath }) { let binaryDisplay; if (isImage(resultPath[resultPath.length - 1])) { binaryDisplay = {'Embedded; } else { binaryDisplay =

Binary content cannot be displayed.

; } return (
{binaryDisplay}
); } function MidSection({ resultPath }) { return (
); } function PageSubstance({ data }) { switch (data.resultType) { case 'home': return ; break; case 'rootDirectory': return (
{data.resultContent.readmeExists && (
)} {data.resultContent.readmeExists && ( )}
); break; case 'nonRootDirectory': return (
); break; case 'textBlob': return (
); break; case 'binaryBlob': return (
); break; case 'commits': return (
); break; } } function Header({ resultPath }) { return (
cleanslatesoftware.com {resultPath.length > 0 && ( / {resultPath[0]} )}
); } function Main({ data }) { switch (data.resultType) { case 'home': case 'rootDirectory': case 'nonRootDirectory': case 'textBlob': case 'binaryBlob': case 'commits': return (
); break; default: return ; } } export { getServerSideProps }; export default Main;